/*
 * Copyright 2022 Chaos Mesh Authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 */
import { OutlinedInput as MuiOutlinedInput, OutlinedInputProps } from '@mui/material'
import { forwardRef } from 'react'

const OutlinedInput = forwardRef(({ sx, ...rest }: OutlinedInputProps, ref) => (
  <MuiOutlinedInput
    size="small"
    sx={{
      px: rest.startAdornment || rest.endAdornment ? 2 : 0,
      borderColor: 'divider',
      typography: 'body2',
      '&:hover': {
        bgcolor: 'action.hover',
        '.MuiOutlinedInput-notchedOutline': {
          borderColor: 'divider',
        },
      },
      '&.Mui-focused': {
        bgcolor: 'none',
        '.MuiOutlinedInput-notchedOutline': {
          borderColor: 'primary.main',
          boxShadow: (theme) => `0 0 0 2px ${theme.palette.secondaryContainer.main}`,
        },
      },
      ...sx,
    }}
    {...rest}
    ref={ref}
  />
))

export default OutlinedInput
